ট্রিস (Trees)

Computer Science - ডাটা স্ট্রাকচার & অ্যালগরিদম (Data Structure & Algorithms)
300

ট্রি (Tree) হল একটি গাণিতিক ডেটা স্ট্রাকচার যা একটি হায়ারার্কিক্যাল মডেল তৈরি করে। এটি মূলত একটি গাছের মতো গঠন, যেখানে একটি মূল নোড (root node) থাকে এবং এটি বিভিন্ন শাখা (branches) এবং পাতা (leaves) নিয়ে গঠিত। ট্রি ডেটা স্ট্রাকচারগুলির মধ্যে বিভিন্ন ধরনের ট্রি রয়েছে, যেমন বাইনারি ট্রি, বাইনারি সার্চ ট্রি (BST), AVL ট্রি, এবং আরও।

ট্রির প্রধান উপাদান

  1. নোড (Node): একটি ট্রির মৌলিক ইউনিট, যা ডেটা ধারণ করে এবং এক বা একাধিক সন্তানের (children) রেফারেন্স ধারণ করে।
  2. রুট (Root): ট্রির সর্বোচ্চ নোড, যা সমস্ত নোডের মূল ভিত্তি।
  3. পাতা (Leaf): নোড যা সন্তানের সাথে যুক্ত নয়; এটি ট্রির শেষ পয়েন্ট।
  4. শাখা (Branch): নোডগুলির মধ্যে সংযোগ।
  5. উচ্চতা (Height): মূল নোড থেকে পাতালোক পর্যন্ত সর্বাধিক স্তরের সংখ্যা।

ট্রির প্রকারভেদ

১. বাইনারি ট্রি (Binary Tree)

বিবরণ: বাইনারি ট্রি একটি বিশেষ ধরনের ট্রি যেখানে প্রতিটি নোড সর্বাধিক দুটি সন্তান (left child এবং right child) ধারণ করে।

বৈশিষ্ট্য:

  • সর্বোচ্চ দুইটি সন্তান।
  • সহজতর গঠন এবং পরিচালনা।

উদাহরণ:

       A
      / \
     B   C
    / \
   D   E

২. বাইনারি সার্চ ট্রি (Binary Search Tree - BST)

বিবরণ: BST হল একটি বাইনারি ট্রি যেখানে প্রতিটি নোডের বাম সন্তানটি তার থেকে ছোট এবং ডান সন্তানটি তার থেকে বড়।

বৈশিষ্ট্য:

  • ইনসার্ট, ডিলিট এবং অনুসন্ধানের জন্য কার্যকরী।

উদাহরণ:

       10
      /  \
     5    15
    / \   / \
   3   7 12  20

৩. AVL ট্রি (AVL Tree)

বিবরণ: AVL ট্রি একটি ব্যালেন্সড বাইনারি সার্চ ট্রি, যেখানে প্রতিটি নোডের বাম ও ডান subtree এর উচ্চতার মধ্যে সর্বাধিক ১-এর পার্থক্য থাকে।

বৈশিষ্ট্য:

  • দ্রুত অনুসন্ধান, ইনসার্ট এবং ডিলিট অপারেশন।

৪. B-Tree

বিবরণ: B-Tree হল একটি মাল্টি-নোড ট্রি যা উচ্চতর ডেটাবেস এবং ফাইল সিস্টেমে ব্যবহৃত হয়। এটি বড় ডেটাসেটের জন্য ডিজাইন করা হয়েছে।

বৈশিষ্ট্য:

  • নোডের মধ্যে একাধিক কীগুলি থাকতে পারে।
  • সব পাতা একই স্তরে থাকে।

ট্রির কার্যকারিতা

  1. ইনসার্ট (Insert): নতুন উপাদান ট্রিতে যুক্ত করা।
  2. ডিলিট (Delete): বিদ্যমান উপাদান ট্রি থেকে মুছে ফেলা।
  3. অবতার (Traversal): ট্রির সকল নোডকে ভিজিট করা, যেমন:
    • ইন-অর্ডার (In-order): বাম subtree -> রুট -> ডান subtree
    • প্রি-অর্ডার (Pre-order): রুট -> বাম subtree -> ডান subtree
    • পোস্ট-অর্ডার (Post-order): বাম subtree -> ডান subtree -> রুট

উদাহরণ (পাইথনে বাইনারি সার্চ ট্রি)

class Node:
    def __init__(self, key):
        self.left = None
        self.right = None
        self.val = key

class BST:
    def insert(self, root, key):
        if root is None:
            return Node(key)
        else:
            if root.val < key:
                root.right = self.insert(root.right, key)
            else:
                root.left = self.insert(root.left, key)
        return root

    def inorder(self, root):
        if root:
            self.inorder(root.left)
            print(root.val, end=' ')
            self.inorder(root.right)

# ব্যবহার
bst = BST()
root = None
keys = [10, 5, 15, 3, 7, 12, 20]

for key in keys:
    root = bst.insert(root, key)

print("In-order traversal: ", end='')
bst.inorder(root)  # আউটপুট: In-order traversal: 3 5 7 10 12 15 20

উপসংহার

ট্রি একটি গুরুত্বপূর্ণ ডেটা স্ট্রাকচার যা ডেটা সংগঠনে সাহায্য করে। এটি বিভিন্ন ধরনের ব্যবহার এবং কার্যকারিতার জন্য বিভিন্ন প্রকারে থাকে, যেমন বাইনারি ট্রি, বাইনারি সার্চ ট্রি, AVL ট্রি এবং B-Tree। ট্রির ব্যবহার বিভিন্ন ডেটা ম্যানিপুলেশন সমস্যার সমাধানে কার্যকরী এবং লাভজনক।

ট্রি এর ধারণা এবং প্রয়োজনীয়তা

221

ট্রি (Tree) এর ধারণা

ট্রি হলো একটি হায়ারারকিক্যাল ডেটা স্ট্রাকচার, যেখানে ডেটা নোড আকারে সংরক্ষিত থাকে এবং প্রতিটি নোডের এক বা একাধিক সন্তান (Child) নোড থাকতে পারে। ট্রি স্ট্রাকচারের প্রতিটি নোডে মূলত দুটি অংশ থাকে:

  1. ডেটা: নোডে রাখা ডেটা।
  2. লিঙ্ক/পয়েন্টার: যা অন্যান্য নোডের সাথে সংযোগ স্থাপন করে।

ট্রি সাধারণত রুট নোড (Root Node) থেকে শুরু হয় এবং প্রতিটি নোড তার শিশু নোডগুলির সাথে সংযুক্ত থাকে। ট্রি স্ট্রাকচারটি গাছের মতো দেখতে, যেখানে একটি মূল নোড থেকে বিভিন্ন শাখা (Branch) ছড়িয়ে থাকে।


ট্রি এর প্রয়োজনীয়তা

১. হায়ারারকিক্যাল ডেটা স্টোরেজ: ট্রি স্ট্রাকচার ব্যবহার করে বিভিন্ন স্তরে ডেটা সংরক্ষণ করা যায়, যেমন: ফাইল সিস্টেম, ক্যাটেগরি ম্যাপিং, সংগঠন চার্ট, এবং ওয়েবসাইটের মেনু।

২. দ্রুত অনুসন্ধান ও ডেটা অ্যাক্সেস: ট্রি স্ট্রাকচার ব্যবহার করে দ্রুত ডেটা অনুসন্ধান এবং অ্যাক্সেস করা যায়, বিশেষত বাইনারি সার্চ ট্রি (BST)-তে, যেখানে O(log n) সময়ে অনুসন্ধান করা সম্ভব।

৩. ডেটা সংযুক্তি ও মুছে ফেলার সুবিধা: ট্রি ডেটা স্ট্রাকচারে নতুন উপাদান যোগ বা মুছে ফেলার কাজ দ্রুত এবং কার্যকরীভাবে করা যায়।

৪. ডায়নামিক ডেটা ম্যানেজমেন্ট: ট্রি স্ট্রাকচার মেমরি ব্যবহারে অনেক কার্যকরী এবং বৃহৎ ডেটাসেট সহজে পরিচালনা করতে সক্ষম। ট্রি স্ট্রাকচারে মেমরি অ্যাসাইনমেন্ট ডায়নামিক ভাবে ঘটে, তাই এটি বড় আকারের ডেটা পরিচালনা করতে সহায়ক।

৫. ডেটার রিলেশনাল রিপ্রেজেন্টেশন: ট্রি স্ট্রাকচারে প্যারেন্ট-চাইল্ড সম্পর্কের মাধ্যমে ডেটা সংরক্ষণ করা যায়। এটি বিভিন্ন ধরনের জটিল সম্পর্ক নির্ধারণ করতে সাহায্য করে, যেমন: গ্রাফিক্যাল রিপ্রেজেন্টেশন, ডিরেক্টরি স্ট্রাকচার ইত্যাদি।


ট্রি এর প্রকারভেদ

১. বাইনারি ট্রি (Binary Tree): একটি ট্রি যেখানে প্রতিটি নোডের সর্বোচ্চ দুটি সন্তান থাকতে পারে।

২. বাইনারি সার্চ ট্রি (Binary Search Tree): একটি বিশেষ বাইনারি ট্রি যেখানে প্রতিটি নোডের বাম দিকের সন্তান ছোট এবং ডান দিকের সন্তান বড় হয়।

৩. ব্যালেন্সড ট্রি (Balanced Tree): একটি ট্রি যেখানে প্রতিটি স্তরে প্রায় সমান সংখ্যক নোড থাকে, যেমন AVL Tree এবং Red-Black Tree।

৪. বাইনারি হিপ (Binary Heap): একটি সম্পূর্ণ বাইনারি ট্রি, যেখানে প্রতিটি প্যারেন্ট নোড তার চাইল্ড নোডগুলির চেয়ে বড় বা ছোট হয় (যেমন: Max Heap, Min Heap)।

৫. B-Tree এবং B+ Tree: সাধারণত ডাটাবেজে ব্যবহার করা হয়, যা বড় ডেটা স্টোরেজের জন্য কার্যকর।

৬. ট্রাই (Trie): একটি বিশেষ ধরনের ট্রি যা স্ট্রিং বা শব্দ সংরক্ষণে ব্যবহৃত হয়, যেমন: ডিকশনারি অ্যাপ্লিকেশন।


ট্রি এর প্রধান অপারেশনসমূহ

  1. ইনসার্ট (Insert): ট্রি-তে নতুন নোড যোগ করা।
  2. ডিলিট (Delete): ট্রি থেকে নির্দিষ্ট নোড অপসারণ করা।
  3. সার্চ (Search): ট্রি-তে নির্দিষ্ট নোড খুঁজে বের করা।
  4. ট্রাভার্সাল (Traversal): ট্রি-তে সমস্ত নোড প্রদর্শন করা, যেমন ইন-অর্ডার, প্রি-অর্ডার এবং পোস্ট-অর্ডার ট্রাভার্সাল।

উদাহরণ: বাইনারি সার্চ ট্রি (Binary Search Tree) তৈরি ও ব্যবহার (Python)

class Node:
    def __init__(self, data):
        self.data = data
        self.left = None
        self.right = None

class BinarySearchTree:
    def __init__(self):
        self.root = None

    def insert(self, data):
        if self.root is None:
            self.root = Node(data)
        else:
            self._insert(data, self.root)

    def _insert(self, data, current_node):
        if data < current_node.data:
            if current_node.left is None:
                current_node.left = Node(data)
            else:
                self._insert(data, current_node.left)
        elif data > current_node.data:
            if current_node.right is None:
                current_node.right = Node(data)
            else:
                self._insert(data, current_node.right)

    def search(self, data):
        return self._search(data, self.root)

    def _search(self, data, current_node):
        if current_node is None:
            return False
        elif data == current_node.data:
            return True
        elif data < current_node.data:
            return self._search(data, current_node.left)
        else:
            return self._search(data, current_node.right)

# ট্রি ব্যবহার
bst = BinarySearchTree()
bst.insert(10)
bst.insert(5)
bst.insert(15)
bst.insert(2)

print(bst.search(15))  # আউটপুট: True
print(bst.search(20))  # আউটপুট: False

উপসংহার

ট্রি হলো একটি কার্যকরী ডেটা স্ট্রাকচার যা হায়ারারকিক্যাল ডেটা ম্যানেজমেন্টে ব্যবহৃত হয়। ট্রি স্ট্রাকচারে ডেটা সংরক্ষণ, অনুসন্ধান এবং পরিচালনা দ্রুত ও কার্যকরীভাবে করা যায়। বিভিন্ন ধরনের ট্রি বিভিন্ন ধরণের ডেটা ম্যানেজমেন্ট প্রয়োজন পূরণে সহায়ক।

বাইনারি ট্রি, বাইনারি সার্চ ট্রি (BST), AVL ট্রি

272

বাইনারি ট্রি, বাইনারি সার্চ ট্রি (BST), এবং AVL ট্রি হল ডেটা স্ট্রাকচারের বিভিন্ন ধরনের গঠন যা গাণিতিক এবং কম্পিউটার বিজ্ঞানে ব্যবহৃত হয়। প্রতিটি ট্রির নিজস্ব বৈশিষ্ট্য, কার্যকরীতা এবং ব্যবহারের ক্ষেত্র রয়েছে। নিচে এই তিনটি ট্রির বিস্তারিত আলোচনা করা হলো।

১. বাইনারি ট্রি (Binary Tree)

বিবরণ: বাইনারি ট্রি হল একটি ট্রি ডেটা স্ট্রাকচার যেখানে প্রতিটি নোডের সর্বাধিক দুটি সন্তান (child) থাকতে পারে। প্রতিটি নোডে একটি মান (value) এবং দুটি পয়েন্টার থাকে: একটি বাম সন্তানের জন্য এবং একটি ডান সন্তানের জন্য।

বৈশিষ্ট্য:

  • প্রতিটি নোডে 0, 1, বা 2 সন্তান থাকতে পারে।
  • বাইনারি ট্রি গভীরতা নির্ভর করে কতগুলি স্তর রয়েছে।
  • বিভিন্ন বাইনারি ট্রির ব্যবহার হতে পারে, যেমন পূর্ণ বাইনারি ট্রি, সম্পূর্ণ বাইনারি ট্রি, এবং সাধারণ বাইনারি ট্রি।

উদাহরণ:

       A
      / \
     B   C
    / \
   D   E

২. বাইনারি সার্চ ট্রি (Binary Search Tree - BST)

বিবরণ: বাইনারি সার্চ ট্রি একটি বিশেষ ধরনের বাইনারি ট্রি, যেখানে প্রতিটি নোডের বাম সন্তানের মান উক্ত নোডের মানের চেয়ে ছোট এবং ডান সন্তানের মান উক্ত নোডের মানের চেয়ে বড়। এটি ডেটা অনুসন্ধান, ইনসার্ট এবং ডিলিট করার জন্য কার্যকরী।

বৈশিষ্ট্য:

  • ইনসার্ট, অনুসন্ধান, এবং ডিলিট অপারেশনের জন্য গড় সময় O(log n)।
  • ইন-অর্ডার ট্রাভার্সাল করলে BST এর এলিমেন্টগুলি ক্রমবর্ধমানভাবে পাওয়া যায়।

উদাহরণ:

       10
      /  \
     5    15
    / \   / \
   3   7 12  20

৩. AVL ট্রি (AVL Tree)

বিবরণ: AVL ট্রি একটি ব্যালেন্সড বাইনারি সার্চ ট্রি, যেখানে প্রতিটি নোডের বাম ও ডান subtree এর উচ্চতার মধ্যে সর্বাধিক 1-এর পার্থক্য থাকে। এটি ডেটার কার্যকরী সঞ্চয় নিশ্চিত করে এবং দ্রুত অনুসন্ধান ও ইনসার্টের জন্য পরিচিত।

বৈশিষ্ট্য:

  • ব্যালেন্সিং: AVL ট্রি ইনসার্ট বা ডিলিট করার পর, যদি কোন নোডের ব্যালেন্স ফ্যাক্টর 1, 0, বা -1 এর বাইরে চলে যায়, তবে তা পুনর্বিন্যাস করা হয়।
  • গড় সময় O(log n) অনুসন্ধান, ইনসার্ট, এবং ডিলিটের জন্য।

উদাহরণ:

       30
      /  \
     20   40
    / \    \
   10  25   50

সারসংক্ষেপ

বাইনারি ট্রি: একটি সাধারণ ট্রি ডেটা স্ট্রাকচার, যেখানে প্রতিটি নোডের সর্বাধিক দুটি সন্তান থাকে। এটি বিভিন্ন ট্রাভার্সাল পদ্ধতি (যেমন ইন-অর্ডার, প্রি-অর্ডার, পোস্ট-অর্ডার) মাধ্যমে ব্যবহার করা হয়।

বাইনারি সার্চ ট্রি (BST): একটি বিশেষ বাইনারি ট্রি, যা ডেটা অনুসন্ধানের জন্য প্রয়োজনীয়। এটি সর্বাধিক দুটি সন্তান ধারণ করে এবং প্রতি নোডের বাম সন্তানগুলি ছোট এবং ডান সন্তানগুলি বড় হয়।

AVL ট্রি: একটি ব্যালেন্সড BST যা নিশ্চিত করে যে গাছের উচ্চতা নিয়ন্ত্রিত থাকে, ফলে সকল অপারেশন (অনুসন্ধান, ইনসার্ট, ডিলিট) কার্যকরভাবে O(log n) সময়ে সম্পন্ন হয়।

এই তিনটি ট্রি ডেটা স্ট্রাকচার বিভিন্ন সমস্যার সমাধানের জন্য ব্যবহার করা হয় এবং তাদের বিভিন্ন বৈশিষ্ট্যের কারণে উপযুক্ত পরিস্থিতিতে সঠিকভাবে নির্বাচন করা প্রয়োজন।

ট্রাভার্সাল মেথড: ইনঅর্ডার, প্রি-অর্ডার, পোস্ট-অর্ডার

147

ট্রাভার্সাল মেথড (Traversal Methods)

ট্রি ডেটা স্ট্রাকচারে ট্রাভার্সাল হল একটি প্রক্রিয়া যার মাধ্যমে আমরা ট্রির সমস্ত নোডগুলি ভিজিট করি। প্রধান তিনটি ট্রাভার্সাল মেথড হল ইনঅর্ডার (In-order), প্রি-অর্ডার (Pre-order), এবং পোস্ট-অর্ডার (Post-order)। প্রতিটি পদ্ধতির নিজস্ব ব্যবহার এবং বৈশিষ্ট্য রয়েছে।

১. ইনঅর্ডার ট্রাভার্সাল (In-order Traversal)

বর্ণনা

ইনঅর্ডার ট্রাভার্সালে, প্রথমে বাম সাবট্রি, তারপর মূল (root) নোড, এবং তারপর ডান সাবট্রি পরিদর্শন করা হয়। এই পদ্ধতি সাধারণত বাইনারি সার্চ ট্রির জন্য ব্যবহার করা হয়, কারণ এটি সব নোডকে সজ্জিতকৃত (sorted) অর্ডারে বের করে।

উদাহরণ

  1. বাম সাবট্রি
  2. মূল নোড
  3. ডান সাবট্রি

উদাহরণ কোড (Python):

class Node:
    def __init__(self, key):
        self.left = None
        self.right = None
        self.val = key

def in_order(root):
    if root:
        in_order(root.left)
        print(root.val, end=' ')
        in_order(root.right)

# ট্রি তৈরি করা
root = Node(1)
root.left = Node(2)
root.right = Node(3)
root.left.left = Node(4)
root.left.right = Node(5)

print("In-order Traversal:")
in_order(root)  # Output: 4 2 5 1 3

২. প্রি-অর্ডার ট্রাভার্সাল (Pre-order Traversal)

বর্ণনা

প্রি-অর্ডার ট্রাভার্সালে, প্রথমে মূল নোড, তারপর বাম সাবট্রি এবং তারপর ডান সাবট্রি পরিদর্শন করা হয়। এটি সাধারণত ডেটা স্ট্রাকচারের কপি তৈরি করার জন্য ব্যবহার করা হয়।

উদাহরণ

  1. মূল নোড
  2. বাম সাবট্রি
  3. ডান সাবট্রি

উদাহরণ কোড (Python):

def pre_order(root):
    if root:
        print(root.val, end=' ')
        pre_order(root.left)
        pre_order(root.right)

print("\nPre-order Traversal:")
pre_order(root)  # Output: 1 2 4 5 3

৩. পোস্ট-অর্ডার ট্রাভার্সাল (Post-order Traversal)

বর্ণনা

পোস্ট-অর্ডার ট্রাভার্সালে, প্রথমে বাম সাবট্রি, তারপর ডান সাবট্রি এবং পরে মূল নোড পরিদর্শন করা হয়। এটি সাধারণত মেমরি মুক্ত করার বা ট্রির নির্মাণের জন্য ব্যবহৃত হয়।

উদাহরণ

  1. বাম সাবট্রি
  2. ডান সাবট্রি
  3. মূল নোড

উদাহরণ কোড (Python):

def post_order(root):
    if root:
        post_order(root.left)
        post_order(root.right)
        print(root.val, end=' ')

print("\nPost-order Traversal:")
post_order(root)  # Output: 4 5 2 3 1

উপসংহার

ইনঅর্ডার, প্রি-অর্ডার, এবং পোস্ট-অর্ডার ট্রাভার্সাল হল ট্রি ডেটা স্ট্রাকচার ব্যবহারের মৌলিক পদ্ধতি। প্রতিটি পদ্ধতির নিজস্ব বৈশিষ্ট্য এবং ব্যবহার রয়েছে, যা বিভিন্ন পরিস্থিতিতে উপকারী হতে পারে। এই ট্রাভার্সাল পদ্ধতিগুলি ডেটা স্ট্রাকচারের বিভিন্ন কার্যকারিতা এবং অ্যালগরিদমগুলির উন্নয়নে অত্যন্ত গুরুত্বপূর্ণ।

Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...